

**WHAT IS CLAIMED IS:**

1. A central processing unit (CPU) comprising:

5           a register file including a standard register set and an extended register set,  
              wherein the standard register set comprises a plurality of standard  
              registers, and wherein the extended register set comprises a plurality of  
              extended registers; and

10           an execution core coupled to the register file and to receive a signal indicating an  
              operating mode of the CPU, wherein the execution core is configured to  
              fetch and execute instructions, and wherein the execution core is  
              configured to respond to an instruction by accessing at least one extended  
              register if the signal indicates the CPU is operating in an extended register  
              mode and the instruction includes a prefix portion including information  
              needed to access the at least one extended register.

2.       The CPU as recited in claim 1, wherein the number of standard registers is less  
              than or equal to a number of general purpose registers defined by a CPU architecture, and  
              wherein the number of extended registers is greater than the number of general purpose  
              registers defined by the CPU architecture.

25           The CPU as recited in claim 1; wherein the instruction absent the prefix portion  
              includes register identification information sufficient to identify a selected one of the  
              standard registers, and wherein the prefix portion of the instruction includes additional  
              register identification information needed to identify a selected one of the extended  
              registers.

4. The CPU as recited in claim 1, wherein the encoding of the instruction, including the prefix portion, identifies the at least one extended register accessed by the execution core.

5

5. The CPU as recited in claim 1, wherein the standard register set comprises eight 32-bit general purpose registers defined by the x86 architecture.

10

6. The CPU as recited in claim 5, wherein the eight 32-bit general purpose registers include the EAX, EBX, ECX, EDX, ESP, EBP, ESI, and EDI registers.

7. The CPU as recited in claim 5, wherein the standard register set comprises eight 32-bit general purpose registers defined by the x86 architecture, and wherein the extended register set includes the eight 32-bit general purpose registers of the standard register set and eight additional 32-bit registers not defined by the x86 architecture.

8. The CPU as recited in claim 1, wherein the execution core is configured to fetch and execute variable-length x86 instructions.

9. The CPU as recited in claim 1, wherein the prefix portion comprises an extended register prefix byte, and wherein the extended register prefix byte comprises an extended register key field, and wherein the contents of the extended register key field indicates whether or not the extended register prefix byte includes the information needed to access the at least one extended register.

25

5

10. The CPU as recited in claim 1, wherein the extended register prefix byte includes the information needed to access the at least one extended register only when the extended register key field contains a predetermined extended register key value.

10

11. The CPU as recited in claim 1, further comprising:

a control register for storing information indicating whether or not the extended register mode is globally enabled;

a flags register for storing information indicating whether or not the extended register mode is enabled by a current process; and

generating means for generating the signal indicating the operating mode of the CPU, wherein the signal indicates the CPU is operating in the extended register mode if the extended register mode is globally enabled and enabled by the current process.

12. A computer system comprising:

a central processing unit (CPU) comprising:

a register file including a standard register set and an extended register set, wherein the standard register set comprises a plurality of standard registers, and wherein the extended register set comprises a plurality of extended registers; and

25

an execution core coupled to the register file and to receive a signal indicating an operating mode of the CPU, wherein the execution core is configured to fetch and execute instructions, and wherein the execution core is configured to respond to an instruction by accessing at least one extended register if the signal indicates the CPU is operating in an extended register mode and the instruction includes a prefix portion including information needed to access the at least one extended register.

13. A central processing unit (CPU) comprising:

a register file including a standard register set and an extended register set, wherein the standard register set comprises a plurality of 32-bit general purpose registers defined by the x86 architecture, and wherein the extended register set comprises a plurality of extended registers, and wherein the number of extended registers is greater than the number of general purpose registers defined by the x86 architecture; and

an execution core coupled to the register file and to receive a signal indicating an operating mode of the CPU, wherein the execution core is configured to fetch and execute variable-length x86 instructions, and wherein the execution core is configured to respond to an instruction by accessing at least one extended register if the signal indicates the CPU is operating in an extended register mode and the instruction includes an extended register prefix byte including information needed to access the at least one extended register.

5

14. The CPU as recited in claim 13, wherein the instruction absent the extended register prefix byte includes register identification information sufficient to identify a selected one of the standard registers, and wherein the extended register prefix byte includes additional register identification information needed to identify a selected one of the extended registers.

10

15. The CPU as recited in claim 13, wherein the encoding of the instruction, including the extended register prefix byte, identifies the at least one extended register accessed by the execution core.

16. The CPU as recited in claim 13, wherein the standard register set comprises the EAX, EBX, ECX, EDX, ESP, EBP, ESI, and EDI registers defined by the x86 architecture.

17. The CPU as recited in claim 13, wherein the standard register set comprises eight 32-bit general purpose registers defined by the x86 architecture, and wherein the extended register set includes the eight 32-bit general purpose registers of the standard register set and eight additional 32-bit registers not defined by the x86 architecture.

20

18. The CPU as recited in claim 13, wherein the extended register prefix byte comprises an extended register key field, and wherein the contents of the extended register key field indicates whether or not the extended register prefix byte includes the information needed to access the at least one extended register.

25

5

19. The CPU as recited in claim 18, wherein the extended register prefix byte includes the information needed to access the at least one extended register only when the extended register key field contains a predetermined extended register key value.

10

20. The CPU as recited in claim 13, further comprising:

a control register for storing information indicating whether or not the extended register mode is globally enabled;

10 a flags register for storing information indicating whether or not the extended register mode is enabled by a current process; and

generating means for generating the signal indicating the operating mode of the CPU, wherein the signal indicates the CPU is operating in the extended register mode if the extended register mode is globally enabled and enabled by the current process.

25

21. A central processing unit (CPU) comprising:

a register file including a standard register set and an extended register set, wherein the standard register set comprises a plurality of general purpose registers defined by a CPU architecture, and wherein the extended register set comprises a plurality of extended registers, and wherein the number of extended registers is greater than the number of general purpose registers defined by the CPU architecture, and wherein a width of the extended registers is greater than a width of the general purpose registers defined by the CPU architecture; and

an execution core coupled to the register file and to receive the signal indicating the operating mode of the CPU, wherein the execution core is configured to fetch and execute instructions, and wherein the execution core is configured to respond to an instruction by accessing the entire contents of at least one extended register if: (i) the signal indicates the CPU is operating in an extended register mode, (ii) the instruction includes a prefix portion including information needed to access the at least one extended register, and (iii) the prefix portion includes an indication that the entire contents of the least one extended register is to be accessed.

22. The CPU as recited in claim 21, wherein the CPU architecture is the x86 architecture, and wherein the width of the general purpose registers is 32 bits, and wherein the width of the extended registers is 64 bits.
23. The CPU as recited in claim 22, wherein the standard register set includes the EAX, EBX, ECX, EDX, ESP, EBP, ESI, and EDI registers defined by the x86 architecture.
24. The CPU as recited in claim 23, wherein the standard register set is a subset of the extended register set, and wherein the standard registers form lower ordered portions of extended registers.
25. The CPU as recited in claim 21, wherein the instruction absent the prefix portion includes register identification information sufficient to identify a selected one of the standard registers, and wherein the prefix portion of the instruction includes additional

10  
15  
20  
25

register identification information needed to identify a selected one of the extended registers.

26. The CPU as recited in claim 21, wherein the encoding of the instruction, including the prefix portion, identifies the at least one extended register accessed by the execution core.

27. The CPU as recited in claim 21, wherein the execution core is configured to fetch and execute variable-length x86 instructions.

10  
20  
28. The CPU as recited in claim 21, wherein the prefix portion comprises an extended register prefix byte, and wherein the extended register prefix byte comprises: (i) an extended register key field, wherein the contents of the extended register key field indicates whether or not the extended register prefix byte includes the information needed to access the at least one extended register, and (ii) an operand size override bit, wherein the value of the operand size override bit indicates whether or not the entire contents of the least one extended register is to be accessed.

29. The CPU as recited in claim 21, wherein the extended register prefix byte includes the information needed to access the at least one extended register and the indication that the entire contents of the least one extended register is to be accessed only when the extended register key field contains a predetermined extended register key value.

30. The CPU as recited in claim 21, further comprising:

25  
a control register for storing information indicating whether or not the extended register mode is globally enabled;

a flags register for storing information indicating whether or not the extended register mode is enabled by a current process; and

generating means for generating the signal indicating the operating mode of the CPU, wherein the signal indicates the CPU is operating in the extended register mode if the extended register mode is globally enabled and enabled by the current process.

10